

(A Constituent College of Somaiya Vidyavihar University)

## **Department of Electronics Engineering**



| Course Name:                | Hardware Description Language Lab (2UXL401) | Semester:        | IV      |
|-----------------------------|---------------------------------------------|------------------|---------|
| <b>Date of Performance:</b> | 12/01/2021                                  | <b>Batch No:</b> | B2      |
| Faculty Name:               | Prof. Bhargavi Kaslikar                     | Roll No:         | 1912060 |
| Faculty Sign & Date:        |                                             | Grade/Marks:     |         |

## **Experiment No: 1**

**Title:** Study of basic VHDL code: Adder (Dataflow)

#### **Aim and Objective of the Experiment:**

Write a VHDL code

- a) To implement a half adder.
- b) A full adder using half adder
- c) A 4-bit adder using full adder.

Write a testbench to verify your results for half adder and four bit adder Implement the full adder on CPLD.

To study basic structure of VHDL code and to understand use of test bench for simulation. To know the process for implementation on CPLD.

#### COs to be achieved:

**CO 1**: Use basic Concurrent and Sequential statements in VHDL and write codes for simple applications

**CO 2**: Test a VHDL code and verify the circuit model.

**CO 3**: Synthesize and Implement the designed circuits on CPLD/ FPGA.

#### Work to be done

Upload VHDL codes for half adder, full adder (structural) and four-bit adder (structural) and test bench for half adder and 4-bit adder.

Also Upload Simulation waveforms for 4 bit adder.

Upload scanned image for post lab questions

HDL Laboratory Semester: IV Academic Year: 2020-21



(A Constituent College of Somaiya Vidyavihar University)







HDL Laboratory Semester: IV Academic Year: 2020-21



(A Constituent College of Somaiya Vidyavihar University)







HDL Laboratory Semester: IV Academic Year: 2020-21



(A Constituent College of Somaiya Vidyavihar University)







HDL Laboratory Semester: IV Academic Year: 2020-21



(A Constituent College of Somaiya Vidyavihar University)







HDL Laboratory Semester: IV Academic Year: 2020-21



(A Constituent College of Somaiya Vidyavihar University)

## **Department of Electronics Engineering**





HDL Laboratory Semester: IV Academic Year: 2020-21



(A Constituent College of Somaiya Vidyavihar University)







HDL Laboratory Semester: IV Academic Year: 2020-21



(A Constituent College of Somaiya Vidyavihar University)

#### **Department of Electronics Engineering**





HDL Laboratory Semester: IV Academic Year: 2020-21



(A Constituent College of Somaiya Vidyavihar University)







HDL Laboratory Semester: IV Academic Year: 2020-21



(A Constituent College of Somaiya Vidyavihar University)





#### Post Lab Subjective/Objective type Questions:

Upload Answer of following question before coming to next laboratory.

### Q1. Analyse the following code and write its output.

library ieee;
use ieee.std\_logic\_1164.all;
entity xyz is
port (x,y: in std\_logic;
 z : out std\_logic);
end entity;
architecture arch\_xyz of xyz is
begin
z <= '0' when (x='1' and y='1') else
 '0'when (x='0' and y='0')else
 '1';
end arch\_xyz;

#### Ans:

The given code is similar to XOR gate as the output 'z' is low (0) if both the inputs 'x' and 'y' are same i.e. if both of them are high or if both of them are low at the same time. Output is high if 'x' and 'y' are different.

| <i>J</i> |   |   |  |
|----------|---|---|--|
| X        | у | z |  |
| 0        | 0 | 0 |  |
| 0        | 1 | 1 |  |
| 1        | 0 | 1 |  |
| 1        | 1 | 0 |  |

## 1912060



HDL Laboratory Semester: IV Academic Year: 2020-21



(A Constituent College of Somaiya Vidyavihar University)





# Q 2 Write a test bench for the above code Ans: 1912060 - HOLL POSTLAB 632 library ieee; use iere.sta-logic\_1164.all; end xyz tb; architecture xyz-tb-arch of xyz-tb is component xyz is x,y: In Atd-logic; z: Out Std-logic); end component; Signal x, y, z : Std-logic; but: xyz pat map (x,y,z); process begin wait for 20ns; x <= '0'; y <= '1'; wait for 20 ns; x <= "1"; 4 <= '0'; coait for 20 ns; 26 <= 11; y <= 11'; wait for 20 ns; end process; end;

HDL Laboratory Semester: IV Academic Year: 2020-21



(A Constituent College of Somaiya Vidyavihar University) **Department of Electronics Engineering** 



#### **Conclusion:**

In this experiment we learned the basics of VHDL and how to use Quartus and simulate the wave using Modelsim.

The VHDL code for Half Adder was written first, which was then used to make the Full adder. Then, the full adder was used in the coding of 4-bit adder.

We also learnt to write testbench for the circuit, in which we give various inputs to the circuit so that we can see the output for different conditions.

**Signature of faculty in-charge with Date:** 

HDL Laboratory Semester: IV Academic Year: 2020-21